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AMENDMENTS TO THE CLAIMS 

IlrisHstingofclaimswiUreplaceallpnorversions.andHstinss,ofcto^ 

T itfin ^ of Claims 

1. (Currently Amended) A system for designing a configurable processor, the system 
comprising: 

hardware generation means for, based on a configuration specification including a 
predetermined portion and a user-defined portion, generating a description of a hardware 
implementation of the processor, the predetermined portion specifying a configuration of a core 
register file, and the user-defined portion specifying whether to include a user-defined register 
f5,e . fr..lv i,»..H.fin.d data tvne in the processor in addition to the core register 

file; and 

software generation means for, based on the configuration specification, gcneratmg 
software development tools specific to the hardware implementation; 

wherein the hardware generation means includes register generation means for, based on 
the user-defined portion of the configuration specification, generating a description of the user- 
defined register file separate from and in addition to a description of die core register file in the 
description of the hardware implementation of the processor; and 

the software generation means is for, based on the user-defined portion, including 
software related to the user-defined processor register file in die software development tools. 

2. (Original) The system of claim 1, wherein the software related to the user-defined 
processor register file includes an instruction for accessing elements in the register file according 
to a field of the instruction. 

3. (Original) Thesystemof claim 2, wherein the hardware generation m 

generating at least part of the description of the hardware implementation in a register transfer 
level hardware description language. 
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4 (Previously Prcs««d) The sy««D of claim 1, wherein coofisur.tion speoiScation 
detoes the user-dcSned rajim Sle ^ a sutemen, speciftring the width of eleme«5 ,n the 

user-defiiied register file. 

5 (Previously Presented) THe system of claim 1, wherein the configuration specification 
defines the user-defined register file using a statement ^ecifying the nnmber of elements m the 
user-defined register file. 

6 (Previously Presented) The system of claim 1, wherein the hardware generation means is 
for determining a numb« of at least one of read ports and write ports of the user-defined.register 
file independently of the configuration specification. 

7. (Canceled) 

8. (Original) The system of claim 1, wherein the hardware generation means is for 
generating, as part of the processor hardware implementation description, a description of logic 
to assign write ports of the user-defined register file to instruction operands to minimize data 

staging costs. 

9. (Previously Presented) The system of claim 1, wherein the hardware generation means is 
for generating pipeUne logic for accessing the user-defined register file. 

10. (Original) The system of claim 9, wherein read ports for the user-defined register file are 
read in the earUest stage of any instruction that uses them as a source operand. 

11. (Original) The system ofclaim 9. wherein write ports for the user-defined register file 
are read in the latest stage of any instruction that uses it as a destination operand or in an 
instruction commit stage if later. 

12. (Previously Presented) The system ofclaim 1, wherein the hardware generation means is 
for geneiating, as part of the hardware implementation of the processor, logic to provide a read 
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port for the user-defined register file for each field, within an instruction accessing the user- 
defined register file, used to select a source operand &om the user-defined register file. 

13. (Previously Presented) The system of claim 1, wherein the hardware generation means is 
for generating, as part of the hardware implementation of the processor, bypass logic for 
accessing the user-defined register file. 

14 (Original) The system of claim 13, wherein the hardware generation means is for 
venerating the interlock logic for a given pipeline of the processor described by the configuration 
Specification based on instruction operand and state usage descriptions in the configuration 

Specification. 

15. (Previously Presented) The system of claim 1, wherein the hardware generation means is 
for generating, as part of the hardware implementation of the processor, interlock logic for 
accessing the register file, 

16. (Original) The system of claim 15, wherein the hardware generation means is for 
generating the interlock logic based on scheduling information in the configuration specification. 

17. (Original) The system of claim 15, wherdn the hardware generation means is for 
generating the interlock logic for a given pipehnc of the processor described by the configuration 
specification based on insmoction operand and state usage descriptions in the configuration 

specification. 

j 8. (Original) The system of claim 1. wherein the hardware generation means is for 
generating the processor hardware implementation description to use at least one portion of 
processor logic described by the predetermined portion of the configuration specification to 
support access of the user-defined register file. 

19. (Original) Ilie system of claim 18, wherein the at least one portion of processor logic 
includes address computation logic. 
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20. (Origiml) Tliesystemofclaiml9,wherdntheaddresscoxnputationlogicincludes 
address adder logic. 

21 (Previously Presented) The system of claim 19 wherein the at least one portion of 
processor logic includes data aUgnment logic shared between the portions of the processor 
corresponding to predetermined and user-defined portions of the configuration specification. 

22. (Original) The system of claim 19 wherein the at least one portion of processor logic 



IS a 



data memory. 
23 



(Original) The system of claim 1, wherein the user-defined portion of the configuration 
specification includes adescriptionof an instruction which conditionally writes to the user- 
defined register file. 

24 (Original) The system ofclaiml, wherein the software generation means is for 
venerating, as part of the software relating to the user-defined register file, diagnostic tests for 
design verification and manufacmringof the processor based on the configuration specxficanon. 

25 (Original) The system of claim 1 , wherein: 

the configuration specification includes both reference and implementation semantics for 

instructioiis of the processor; and 

the refemice semantics can be used to verify design correctness of the implementation 

semantics. 

26 (Original) The system of claim 1 , wherein: 

me processor instruction set description language includes instruction test cases; and 
the software generation means is for generating diagnostics for the test cases. 

27 (Original) The system of claim l.whereinthe software generation means is for 
automatically generating test vectors by sampling operands to instructions in the processor 
instruction set description language while nmning an appUcation. 
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28 (Original) The system of claim 1, wherein the software generaticm means is for 
generating least a portion of an operating system as part of the software relating to user- 
defmed states and register files. 

29. (Original) The system ofclaim 28, wherein the generated portion of the operating system 
includes save and restore sequences for processor state. 

30 (Original) The system ofclaim 29, wherein the save and restore sequences are generated 
with respect to interdependencies of component states and is vaUd for those mterdependencies. 

31 (PreviouslyPresented) Hie system of claim 28. wherein the operating system is capable 
of saving less than an entirety of processor state in accordance with a dynamic reference by a 
new task after switching contexts. 

32. (Original) The system ofclaim 28, wherein: 

the user-defined portion of the configuration specification defines a software data type 
not found in the predetermined portion of the configuration specification; and 
the compiler supports the software data type. 

33. (Original) The system ofclaim 1, wherein the software generation means is for 
generating at least one of a compiler, a linker, a simulator and a debugger as part of the software 
relating to the user-defined register file. 

34. (Previously Presented) The system of claim 1, wherem: 

the software generation means is for generating a compiler as part of the software relating 

to the user-defined register file; and 

the compiler is capable of allocating program variables to register* in the user-defined 

register file. 
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35 (Original) The system of claim 34, wherein the compiler is further enable of loading a 
value fiom memory into a registerin the user-defined register file, and storing a value in a 
register of the user-defined register file into memory. 

36 (Original) The system of claim 34, wherein the compiler is fijrther enable of moving a 
value fiom one register in a user-defined register file to another register in a user^efined register 

file. 

37 (Original) The system of claim 34, wherein the compiler is for using scheduling 
infomiation in the configux^tion specificaiion to determine stall cycles of instructions in the 
sofhvare generated by the software generation means which access the user-defined register file. 

38. (Original) The system of claim 1, wherein the software generation means is for 
automaticaUy generating a monitor to check for coverage of bypass paths. 

39. (Previously Presented) A system for designing a configurable processor, the system 
cotnprising: 

hardware generation means for, based on a configuration specification including a 
predetermined portion and a user-defined portion, generating a description of a hardware 

implementation of the processor; and 

software generation means for. based on the configuration specification, generating 
software development tools specific to the hardware implementation; 

wherein the configuration specification includes a statement speci^ng scheduhng 
infomiation of instnicnons used in the software development tools; 

the hardware generation means is for, based on the statement in the configuration 
specification, determining whether and how to generate a description of at least one of pipeline 
logic, pipeline stalhng logic and mstmction rescheduling logic. 

40 (Original) The system of claim 39. wherein the scheduling information includes a 
statement that an operand of an instruction enters a pipeline of the processor at a given stage. 
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41 (Ori<nnal) The system of claim 39, wherein the scheduling information includes a 
statement that an operation of an in^ixuction exits a pipeline of the processor 

42 (Original) The system of claim 39, wherein; 

the software generated by the software generation means includes a compUer which uses 
instructions described in the user-defined portion of the configuration specification; and 

tbe coxBpiler uses the scheduling information during instruction scheduling to schedule 
the instructions described in the user-defined portion of the configuration specification. 

43 (Original) The system of claim 39. wherein the configuration specification includes a 
description of an instruction which requires a plurality of processor cycles to be processed. 

44 (Original) The system of claim 43, wherein: 

the configuration specification includes ^ description of an instruction's semantics which 
is independent of a target pipeline of the processor; and 

the hardware generation means is for generating as part of the processor hardware 
in^plementation a pipeline based on a pipeUue description separate fioxn the instruction semantics. 

45. (Original) A system for designing a configurable processor, the system comprising: 
hardware generation means for. based on a configuration specification including a 

predetermined portion and a user-defined portion, generating a description of a hardware 

implementation of the processor; 

software generation means for, based on the configuration specification, generating 
software development tools specific to the hardware implementation; and 

document generation means for generating documentation of a processor instruction set 
described by the configuration specification based on the configuration specification. 

46. (Original) The system of claim 45. wherein the document generation means is for using 
reference semantics of instructions defined in the configuration specification to generate the 
processor instruction set documentation. 
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47 (Original) The system ofclaim 45, wherein; 

the user^defined portion of the configuration specification contains reference semantics of 
an instruction defined therein and a user-defined specification of at least one of a sjoiopsis and a 
text description for the user-defined insmiction; and 

the document generation means is for using the at least one of the synopsis and the text 
description to generate documentation of the processor instniction set. 

48. (Previously Presented) A system for designing a configurable processor, the system 

comprising; 

hardware generation means for, based on a configuration specification including a 
predetermined portion and a user-defined portion, generating a description of a hardware 

implementation of the processor, and 

software generation means for, based on the configuration specification, generating 
software development tools specific to the hardware implementation; 

wherein the user-defined portion of the configuration specification includes a user- 
defined specification of a processor exception and when a processor instruction raises the 
exception; and 

the hardware generation means includes user-defined exception support generating means 
for generating hardware supporting that user-defined exception as part of the processor hardware 
implementation. 

49. (Original) A processor simulation system comprising: 

hardware simulation means for executing a hardware description of an extensible 

processor; 

software simulation means for executing a software reference model of the extensible 

processor, and 

cosimulation means for operating the hardware simulation means and the software 
simulation means and comparing results of simulations therefrom to establish coiiespondence 
between the hardware description of the extensible processor and the software reference model 
of the extensible processor. 
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50 (Previously PT««««i) The processor simuWon .ystem of claim 49. »he«in the 
hardw^e descriptioa of the extensible processor includes a description of h«dware supportwg 

one or more user-defined instructions. 

51 (Previously Presented) The processor simulation system of cbim 50, wherein the 
software reference model includes a model of the extensible processor including the one or more 
user-defined instnictions. 

52 (Previously Presented) The processor simulation system of claim 49. wherein die 
hardware description of the extensible processor executed by the hardware simulation means 
includes a description of one or more user-defined states. 

53 (Previously Presented) The processor simulation system of claim 52. wherein the 
software reference model executed by the software simulation means includes a model of the 
extensible processor including the one or more user-defined states. 

54 (Previously Presented) The processor simulation system of claim 53. wherein the 
cosimulation means establishes correspondence of all the processor states, including the user^ 
defined states, between the hardware description of the extensible processor and the software 
reference model of the extensible processor. 

55 (Previously Presented) The processor simulation system of claim 49. wherein the 
hardware description of the extensible processor executed by the hardware simulation means 
includes a description of one or more user-defined register files. 

56. (Previously Presented) The processor simulation system of claim 54, wherein the 
software reference model executed by the software simulation means includes a model of the 
extensible processor including the one or more user-defined register files. 

57 (Previously Presented) The processor simulation system of claim 56, wherein the 
cosimulation means estabUshes correspondence of aU the processor register files, including the 
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^.defined regi^er files, between the hardware description of the ^^^^^^ 
software reference model of the extensible processor. 

58 (Currently Amended) The system of claim 39, wherein the u.er-defined portion of the 
configuration specification supports one ormorc user-defmed imtructions rh.t are added to a 
p»-HpfinMl instP"-rtnii set of the processor. 

59. (Previously Presented) Thesystemof claim 39, wherein the instructions used in the 
software development tools include one or more user-defined instructions. 

60 (Previously Presented) The system of cto 39, wherein the pipeline logic, pipeline 
stalling logic and instruction rescheduling logic are for supporting one or .more user-defined 

instructions. 

61 (Currently Amended) The system of claim 45. wherein the user-defined portion of the 
configux^tion specification supports one or more user-defined instruction s that added to a 
pr^a^finfed u .»*r!'^*'<*" sfet processor. 

62. (Previously Presented) The system of claim 45. wherein the processor instruction set 
includes a predetemined portion and a user-defined portion. 

63 (Currently Amended) Hie system of claim 48, wherein the user-defined portion of the 
configuration specification supports one or more user-defined instructions that are added to n 
prfi-defined irt«=triirtion se t nf the nrocessor. 

64. (Previously Presented) The system of claim 48, wherein the processor instruction is a 
user-defined instruction. 

65 (New) The system of claim 1, wherein the user-defined portion of the configuration 
specification supports one or more user-defined instructions that are added to a pre-defined 
instruction set of the processon 
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